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© A single chip microcomputer comprises a control circuit (I2a. I2b). a processing circuit (I3a. 13b) and a 
piurality of address register - status register pairs. A logical unit formed within the control circuit (I2a, l2b) 
comprises an electrically writable non-volatile semiconductor memory device. Information can be externally 
written into the non-volatile semiconductor memory included in the logical unit, and the plurality of address 
register - status register pairs can be arbitrarily selected. As a result, logic function of the logical unit can be 
arbitrarily established in accordance with externally supplied information. Demanded specifications of vanous 
users can be satisfied by the logic function thus arbitrarily formed. 
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SINGLE CHIP MICROCOMPUTER 



BACKGROUND OF THE INVENTION 

The present invention relates to a semiconductor integrated circuit, and in particular to a single chip 
microcomputer (hereatter referred to as microcomputer). Further, the present invention relates to a 
5 semiconductor integrated circuit suitable for significantly reducing the number of components in constituting 
a system and suitable for shortening the development interval of an application system. 

In apparatus of prior art. a microcomputer and a Pl-A (programmable logic array) are fabricated to form 
one chip, and the PLA functions in response to an external input irrespective of the program of the 
microcomputer. Outputs of the PLA then activate various functions and the microcomputer is started by the 
to result thereof. 

The PLA is a logic circuit apparatus having a variable logic structure, the logic function of which can be 
arbitrarily constructed by electrical write operation to a non-volatile semiconductor memory device. 

On the other hand, an improved PLA using the EPROM technique is disclosed in U,S. Patent No. 
4.609.986. 

ts Further, as a semiconductor Integrated circuit apparatus having a data processing unit such as a CPU 

and a non-volatile memory block for storing therein software in an identical chip, a semiconductor integrated 
circuit apparatus disclosed in JP-A-60- 198667 is known. 

On the other hand, electrically writable logic devices are discussed in products catalogue of Altera 
Corporation, p. 12 or Electronic Design, 1986. Aug. 7. pp. 94 to 97. 

20 The prior art apparatus disclosed in the aforementioned JP-A-61 -285567 has the effect of reducing the 

number of components in some application. However, readiness to general use is not so deeply considered, 
and hence wide range applications cannot be covered, resulting in a problem. Further, the aforementioned 
U.S. Patent No. 4.609.986 discloses only PLA itself. This patent discloses only provision of a desired singi 
chip microcomputer to the user in a short delivery time achieved by integrating the PLL. i.e.. the 

25 programmable logic circuit and the microcomputer into one chip, by constituting a memory block for storing 
therein a program, which is software of the single chip microcomputer, in 'the form of a non-volatile memory, 
and by writing the program into the non-volatile memory for storing the program from the outside of the 
chip under the directive of the user itself. Contrivances allowing the user itself to freely construct a logic 
apparatus for implementing hardware of a single chip microcomputer was not considered. 

30 The software (program) of the single chip microcomputer is developed, and the software thus 
developed is written into the ROM (read only memory) of the memory block of the single chip microcom- 
puter. If this ROM is composed of a non-volatile memory and the user itself freely writes program into this 
non-volatile memory from the outside of the chip, therefore, the user can obtain a single chip microcom- 
puter containing desired software in a short time. 

35 As for the hardware of the single chip microcomputer as well, respective users often have various 

requirement specification. Therefore, it is not possible to satisfy simultaneously various requirement 
specification of the user with unified hardware. In the prior art. therefore, a random logic circuit or the lik is 
added as an external circuit of the single chip microcomputer in order to realize requirement specification of 
respective users themselves, resulting in problems of a large number of components used in the overall 

40 system and a large mounting area. Basic configuration of a single chip microcomputer for solving this 
problem is already disclosed in JP-B-63-91563 (U.S. Patent Application Serial No. 238,534 filed on August 

31. 1988 in United States). 

As examples of the hardware of a single chip microcomputer for which respective users have their 
peculiar requirement specifications, various examples such as a key input encoder (which is an encoder for 
45 converting information inputted from a keyboard and for taking the resultant information into the single chip 
microcomputer), a display decoder (a decoder for convertingHnformation outputted from the single chip 
microcomputer and for driving a display unit), a time measuring timer and a serial communication circuit 
can be mentioned. 
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SUMMARY OF THE INVENTION 

An object of the present invention is to provide logic configuration and circuit configuration suitable for 
implementing a higher speed and a minimized chip size in implementing the single chip microcomputer 
disclosed in the above described patent application in an LSI form. 
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Other objects of the present invention will be nnade clear from following description and drawings. 
In accordance with a representative aspect of the invention disclosed in the present application, a logic 
unit formed within a single chip microcomputer comprises a control circuit having an electrically writable 
noh-volatile semiconductor memory device, a processing circuit and a plurality of pairs of address registers 
and status registers. 

From the outside of the chip, the user can write information into the non-volatile semiconductor memory 
included in this logic unit. The control circuit is so configured that it may arbitrarily select one pair out of the 
above descnbed plurality of pairs of address registers and status registers in response to information thus 
written into the non-volatile semiconductor memory. 

Owing to the above described configuration, the above described pair of address register and status 
register can be selectively connected to one processing circuit. Since the logic function of the logic unit can 
ihus be arbitrarily formed in response to information written into the non-volatile semiconductor memory, it 
is possible to satisfy requirement specifications of various users with the logic functions thus formed 
arbitrarily. 

Further, by defining independently as many functions as the above described pairs of address registers 
and status registers and by controlling selection of those pairs of address registers and status registers in a 
time division scheme, operation looking as if a plurality of independent programs are operating can be 
realized by using a single processing circuit. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Fig. 1 is a block diagram of a subprocessor which is an embodiment of the present invention. 
Fig. 2 is an entire configuration diagram of a single chip microcomputer which is an embodiment of 
the present invention. 

Fig. 3 is a detailed configuration diagram of the subprocessor and a programmable I/O per channel. 
Fig. 4 is a diagram showing instructions specified in a micro EPROM. 
Fig. 5 is a diagram showing the configuration of a register. 

Figs. 6a, 6B. 60 and 6D are diagrams showing connection of processing circuits used when timer 
function is to be implemented. 

Fig. 7 is a status transition diagram of a memory access circuit. 

Fig. 8 is a configuration diagram showing an address register, a status register and their vicinities. 

Figs. 9A and 9B are diagrams showing operation sequences in the configuration of Fig. 8. 

Fig. 10 is a diagram showing the configuration of a control PLA and an event driven control circuit. 

Figs. 1 1 A and 1 1B are diagrams showing program of the control PLA of Fig. lO. 

Fig. 12 is a diagram showing operation timing of event driven control. 

Fig. 13 is a configuration diagram showing an address register, a status register and their vicinities in 
performing pipeline control. 

Fig. 14A is a diagram showing the configuration of an output circuit of Fig. 13. 
Fig. 14B is a diagram showing the operation sequence of the circuit of Fig. 13. 

Fig. 15 is a diagram showing the sequence used when pipeline control is performed by the circuit of 
Fig. 13. 

Fig. 16 is a configuration diagram of an initial value control circuit. 

Fig. 17 is a diagram showing the program of a control PLA of Fig. 16. 

Fig. 18 is a configuration diagram of a programmable I/O. 

Figs. 19A and 198 are configuration diagrams of non-volatile switch circuits. 

Fig. 20 is a configuration diagram of a PLD. 

Fig. 21 is a configuration diagram for testing the single chip microcomputer. 

Fig. 22A is a configuration diagram for testing a subprocessor. 

Fig. 228 is a diagram showing a test sequence of the circuit of Pig, 22A. 

DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Preferred Embodiments of the present invention will hereafter be described in detail. 
Fig. 2 shows entire configuration of a single chip microcomputer which is an embodiment of the present 
invention. 

A microcomputer 1 comprises on one semiconductor substrate: 
a main processor 5 including a CPU (central processing unit) 2. a RAM 3 and an EPROM (electrically 
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writable read only memory) 4; 
a subprocessor (SP) 6: 

an electrically writable programnnable logic device (PLD) 7; 
programmable I/O ports (PI/0) 8 and 199: and 
5 a common bus 9 for connecting the above described blocks together. 

Among the above described components, the EPROM 4 is a memory for storing therein information 
regarding the operation of the CPU 2. It is possible to electrically write information from the outside of the 
chip into the EPROM 4. 

Further, the above described subprocessor (SP) 6. programmable logic device (PLD) 7 and program- 

10 mable I/O ports (Pl/O) 8 and 199 are logic units respectively havirig therein non-volatile semiconductor 
memories into which information can be electrically written outside the chip. Each of these logic units 
comprises a control circuit for prescribing connection relations of components included in the unit and for 
realizing desired logic circuit configuration in response to information written into a non-volatile semiconduc- 
tor memory included in the above described unit. 

;5 The above described subprocessor (SP) 6 has therein a processor unit corresponding to the CPU 2 
included in the main processor 5. In the present embodiment, the main processor 5 is used mainly for 
general calculation, whereas the subprocessor 6 is used mainly for functional processing such as I/O 
control. From this point of view, the main processor 5 and the subprocessor 6 have different instruction sets 
corresponding to respective purposes of use. 

20 Further a DRAM or the like disposed outside the microcomputer 1 can also be connected to the 
microcomputer 1 as an external memory. In this case, a DRAM or the like is connected to the 
microcomputer 1 via an external memory I/O circuit (not illustrated) connected to the common bus 9 shown 
in Fig. 2. If the address space of this external memory is made common to the address space of the RAM 3 
and the EPROM 4. it is possible to easily gain access to this external memory from the subprocessor 6, not 

25 to mention from the subprocessor 6. ^ 

Configuration and operation of the subprocessor 6 and the programmable I/O 8 will now be described 
by referring to Fig. 1. Main portions of the invention disclosed in the present application exist m this portion. 

30 CONFIGURATION OF SUBPROCESSOR AND PROGRAMMABLE I/O 

Fig. 1 is a diagram showing the configuration of the subprocessor 6 and the programmable I/O port 
(programmable I/O) 8 illustrated in Fig. 2. The subprocessor 6 comprises two processor channels (channel 
A 10a and channel B lOb) having identical configuration. 
35 Each subprocessor channel comprises: 

a micro ROM (read only memory) 1 1 for storing therein microinsiructions: 

a control circuit 12 for generating control information in accordance with information stored in the micro 
ROM 11; 

a processing circuit 13 controlled by the control circuit 12; 
40 a control PLA (programmable logic array) 14 for controlling the above described micro ROM 1 1, the control 
circuit 12 and the processing circuit 13; and 

a port interface circuit 15 coupled to the processing circuit 13 and the control PLA 14. 

Further the subprocessor 6 comprises a processor interface circuit 16 for communicating with the mam 
processor 5. This interface circuit 16 is coupled to both the subprocessor channel A lOa and the 

45 subprocessor channel B 10b. The programmable I/O 8 has two channels corresponding to the above 
described subprocessor channels. Each channel comprises an I/O circuit (I/O) 18 associated with the port 
interface circuit 15 of the subprocessor 6 and comprises an interrupt status flag (ISF) 56. 

Further, the programmable I/O 8 comprises an interchannel interface circuit 19. This mterface circuit 19 
is coupled to 1/0 A 18a. ISFA 56a. I/O B 18b and ISFB 56b. . u * 

so Fig. 3 shows detailed configuration of the subprocessor and the programmable I/O per channel. Each of 
the micro ROMs shown in Fig. 1 comprises an EPROM (electrically writable read only memory), which is 
hereafter referred to as micro EPROM 11. Outputs of the. micro EPROM 11 are inputted to the control 
circuit 12. In this micro EPROM 11. eight fields form one microinstruction word (i.e.. one word). Eight fields 
are listed below. 

55 (1) Instruction specifying field 

(2) Data length specifying field 

(3) Register selecting field 

(4) Numerical data field 
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(5) Next address control field 

(6) Port specifying field 

(7) Output compare specifying field 

(8) Input capture specifying field This microinstruction word will be described later in detail. Further. 
5 inputs to the micro EPROM 1 1 are supplied by an address register circuit 20. This address register circuit 

20 is controlled by an address control circuit 21 included in the control circuit 12. This address control 
circuit 21 is a circuit for generating an aadress of the micro EPROM n on the basis of a status output 
supplied from a processing unit 26 and information supplied from the I/O circuit 18. The output of the 
address control circuit 21 is connected to the above described address register circuit 20. The address 
JO register circuit 20 is capable of storing a plurality of pieces of address information. Which of the plurality of 
addresses is selected depends upon the control of the control PLA 14. In response to information stored 
beforehand in the micro EPROM n. the processing control circuit 22 included in the control circuit 12 
controls connection relations of components included in the processing unit 26 in the processing circuit 13. 
Similarly in response to information stored in the micro EPROM 11. a register control circuit 23 controls 
- /5 connection relations of respective registers included in a register circuit 42 in the processing circuit 13. 

Configuration of the processing circuit 13 controlled in operation by the control circuit 12 will now be 
described in detail. 

The processing circuit 13 comprises the processing unit 26. a status register SR containing at least 
either one of carry flag (OF) and zero flag (2F) or typically both of them, and the register circuit 42. 
30 The processing unit 26 is provided to execute an instruction described in the instruction specifying field 

of the micro EPROM. The processing unit 13 comprises an anthmetic and logic unit (ALtJ) 71 and a 
comparator CMP. 

The ALU 71 and the comparator CMP can operate simultaneously. Inputs of the ALU 71 and the 
comparator CMP are connected to a first read bus 25 and a second read bus 32. The output of the ALU is 

25 inputted to a write bus input selector 34. The output of the CMP is connected to a write bus output control 
circuit 35 and a zero flag input selector 36. A zero generation circuit 37 is connected to another input of the 
write bus input selector 34. The zero generation circuit 37 is a circuit used by INCCLR (increment and 
clear) instruction which will be described later. The zero generation circuit 37 outputs "0" as data to a write 
bus 31 when the output of the CMP is *M ". That is to say. the zero generation circuit 37 is used to clear a 

30 register specified as a counter register. 

The ALU is connected to the status register SR via the zero flag input selector 36 and a carry input 
selector 38. Further, a carry input 39 to the ALU can be forcibly defined to be '*0" or "I" by specifying 
information to be stored in a carry input specifying field included in the instruction specifying field of the 
micro EPROM 1 1 in addition to the carry flag contained in the above described status register SR. Further. 

35 a port data tine 69 for transferring an input signal from a port in accordance with specification of the above 
described field can also be used as the carry input 39 of the ALU. 

The register circuit 42 comprises registers RO to Rl9. RIMM and RFRT and comparators COl. C23. 
045 and C67 exclusively used for output comparing function. The registers RO to Rl9 are connected to the 
first read bus 25. the second read bus 32 and the write bus 31 in common. Read only registers RIMM and 

JO RFRT are connected to only the read buses. One inputs of the comparators COl. C23. C45 and C67 are 
connected to the registers RO. R2. R4 and R6. respectively. The other inputs of those comparators are 
connected to the second read bus 32 in common. Output lines 44a to 44d of the above described 
comparators are inputted to the port interface circuit 15. This port interface circuit 15 is controlled by a 
signal on an output control line 43 generated on the basis of bits contained in the output compare 

as specifying field of the micro EPROM. Further, the registers R9 to R11 have input capture function. Inputs 
from the write bus 31 to these registers R9 to R11 are controlled by input capture input control lines 45 
supplied from the port interface circuit 15. A read/write bus 46 for interfacing with the main processor 5 is 
provided and connected to the registers RO to R19 in common so that the main processor 5 shown in Fig. 2 
may directly gain access to the registers RO to Ri9. By arranging the registers RO to R19 in the address 

•50 space of the main CPU 2. it is possible to freely gain access to the registers RO to R19 from the main CPU 
2 as well. In this case, the main CPU 2 and the subprocessor 6 can simultaneously read contents of an 
identical register. If simultaneous write attempts to an identical register occur, the write attempt from the 
main CPU 2 takes precedence and the write attempt from the subprocessor 6 becomes null. Data 
interchange with the main CPU 2 is performed via the processor interiace circuit l6. 

55 

OPERATION OF MICROINSTRUCTION AND SUBPROCESSOR 
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Operation of the microinstruction, subprocessor and programmable I/O will now be described in detail. 
Here, description of each of the eight fields included in a microinstruction word and operation of the 
processor and the programmable I/O responsive to the description are successively described. 

5 

(1) Instruction specifying field 

This field is a field for specifying the processing function of the processing unit 26 around the arithmetic 
and logic unit (ALU) 71 and operation of the status register (SR). 
10 Instructions can be divided into ® general insructions. ® timer instructions and Q) mennory access 

instructions. Fig. 4 is a list of instruction sets. 

® General instructions 

IS 

• Transfer: MOVE 

• Arithmetic operation: ADD/Ci, SUB/Ci 

• Logic operation: AND. OR. ERO 

• Shift: LSUGi. LSR/Ci 
20 • No operation: NOP 

Ci denotes a carry input to the processing unit and can be specified as follows. 

• Ci = 0 

• Ci = 1 

• Ci = CF (carry flag of SR) 

25 '01 = Pi (data of input port specified by (6) port specifying field described later) 

® Timer instruction 

• INCCLR: Increment and clear. Contents of a first register and a second register included in the register 
30 circuit 42 are compared by a comparator CMP. If contents of those registers are equivalent, a logic .1 is 

stored into the zero flag (2F) of a status register (SR) 70. and the first register is cleared. Unless contents of 
those registers are equivalent, a logic 0 is stored into the 2F. and data of the first register is increased by 
the ALU 71. 

• INCCMP: Increment and compare. Contents of the first register and the second register are compared by 
35 the comparator CMP. If contents of those registers are equivalent, a logic 1 is stored into the ZF. Unless 

contents of those registers are equivalent, a logic 0 is stored into the 2F. Further, in either case, data of the 
first register is increased by the ALU 71. 

• DECLD: Decrement and load. Data of the first register is decreased by the ALU 71. If the result is zero 
(i.e.. (2F) = 0), data of the second register is transferred to the first register. 

JO 

(3) Memory access instruction 

• WRSET: Write set. A source register or numerical data is transferred to a data buffer . 

• WRSTART: Write start. A source register or numerical data is transferred to an address buffer, and a 
45 write cycle is started. 

• RDSTART: Read start. A source register or numerical data is transferred to the address buffer, and a read 
cycle is started. 

• RDGET: Read get. Contents of the data buffer are transferred to a destination register. 

• REF: Refresh. A source register or numerical data is transferred to the address buffer, and a refresh cycle 
50 is Started. 

In Fig, 4, B/W in data length column represents data length which can be handled by each instruction. 
The data length is specified by a field described below in (2). 

55 (2) Data length specifying field 

This is a field for specifying either 8 bits (byte or B) or 16 bits (word or W) as the data length 
processed in the processing unit 26 and the size of each register in the register circuit 42. 
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(3) Register selecting field 

This is a field for simultaneously specifying two registers (a source register and a destination register 
Ro) involved in processing in the processing unit out or registers included in the register circuit 42. Whether 

5 the specified registers have bytes as unit or words as unit depends upon the specification of the field 
described above"in (2).' It is possible to specify a numerical register (RIMM) as the register. In this case, the 
numerical data described in the numerical data field which wiil be described later in (4) is involved in 
processing. If a numerical register is specified as the destination register, the result of processing is 
reflected into only a status register, and result data is discarded. 

70 Fig. 5 shows configuration of registers incorporated in the register circuit 42. In Fig. 5. general purpose • 

registers RO to R19 can be used as 16 bit x 20 registers or 8 bit x 40 registers. Register RIMIVl {'5) is a 
register reflecting the numerical data described in the micro EPROM and is a read only register. Register 
RFRT (-6) IS a register reflecting the value of a 16-btt free running timer supplied with clocks as input and is 
a read only register. R0/R1. R2/R3, R4/R5. and R6/R7 can also be used respectively in pairs as registers 

/5 having output compare function. In case output compare specification is present in the output specifying 
field which will be described later in (7). those registers are automatically ensured in pairs. 

Among the above described pairs. R0/R1 and R2/R3 are used exclusively for 16 bits, whereas R4/R5 
and R6/R7 can be used for both 16 bits and 8 bits. Whether those registers are used for 16 bits or 8 bits is 
specified by the data length specifying field described above in (2). Registers R8 to R11 can be used as 

20 input capture registers as well. Whether the registers R8 to Rl 1 are used as input capture registers or not 
IS specified in the input capture specifying field which wilt be described later in (8). 



f4) Numerical data field 

25 

This IS a field for describing numerical data in case a numerical register (RIMM) is specified in the 
register selecting field described above in (3). 

30 (5) Next address control field 

This is a field for describing which address is selected as the next microinstruction succeeding the 
microinstruction which is being executed, into this field, a branch condition and two dlHerent addresses 
(address 0 and address i ) for allowing the destination of branch to be changed on the basis of whether the 
35 condition is satisfied or not can be described. 

As the branch condition, either one of a carry flag CF and a zero flag ZF contained in the status register 
SR. a carry C generated as a result of processing performed by an instruction in execution, zero Z and data 
Pi in an input port specified by a port specifying field described below in (6) can be specified. When the 
specified condition is satisfied, address 0 is selected as the next address. When the specified condition is 
40 not satisfied, address i is selected. 



(6) Port specifying field 

^5 This is a field for specifying which bit among a plurality of bits stored in the programmable I/O 8 should 

be selected and how the I/O bit thus selected should be operated. Decoding of the information stored in this 
field and control of the above described selection and operation specification are performed tiy the port 
interface circuit 15. This I/O bit thus specified is hereafter referred to-as simply port. 

In this field, three ports can be simultaneously specified. Three bits. i.e.. three ports specified in this 
?o port specifying field are referred to as Pc. Pt and Pck- 

(T) The following three operations can be specified in Po. 

• A port is specified as neither input not output. 

• A port is specified as input. The specified port is used as an input pea. 

• A pon is specified as output. The specified port is used as an output port. In this case, it is possible to 
55 specify what is used as the output condition and operations respectively performed when the output 

condition is satisfied and when the output condition is not satisfied. 

Table 1 shows kinds and contents of conditions which can be used as the above described output 
condition. Table 2 shows how operations "through'*. "0 output". "1 output" and "inversion" are performed 

7 
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on the basis of whether conditions of Table 1 are satisfied or not. 

TABLE 1 



Output 
condition 


Contents 


All 


Unconditional 




Z 


Processing result. is zero 


(=) 


2 


Processing result is not zero 


(*) 


C 


Carry is present 


(>) 




Carry is not present 


(S) 


2 + C 






2 + C 




(<) 



TABLE 2 



Operation 


Condition is 
satisfied 


Condition is 
not satisfied 


Through 


1 output 


0 output 


0 output 


0 output 


No change 


1 output 


1 output 


No change 


Inversion 


Inversion 


No change 



(5) The following two operations can be specified in Pi, 

• Output is absent. 

• Output is present, tn this case, output condition (TABLE 3) and operation at that time (TABLE 4) can t 
specified in the same way as the previous case of Po. Unlike the case of Po. the status of Po can fc 
specified as the output condition. 

TABLE 3 



Output 
condition 


Contents 


All 


Unconditional 




Z 


Processing result is zero 


( = ) 


z 


Processing result is not zero 


(^) 


c 


Carry is present 


(>) 


c 


Carry is not present 


(^) 


z + c 




{^) 


z + c 




(<) 


Po 


Po input is 1 






Po input is 0 
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TABLE 4 



to 



Operation 


Condition is 
satisfied 


Condition is 
not satisfied 


Through 


1 output 


0 output 


0 output 


0 output 


No change 


1 output 


1 output 


No change 


Inversion 


Inversion 


No change 



@ The following two operations can be specified in Pck- 
15 ' Skip control is not present. 
' Skip control is present. 

Skip control is control for invalidating an instruction which is being executed. If skip specification is 
present and the input to the specified port is i. (he instruction which is being executed is continued. If the 
input to the specified port is 0. however, the instruction which is being executed is invalidated. When the 
20 instruction is invalidated, states of the register, the status register and the output port are not changed. 

(7) Output compare specifying field 

25 This is a field for specifying that the processing circuit i3 should perform output compare operation. If 

the output compare is specified in this field, the registers RO to R7 included m the register circuit 42 are 
ensured m pairs two by two. and a processing circuit configuration adapted to output compare is 
implemented. 

Fig 6A is a diagram showing the configuration of the processing circuit 13 connected for output 

30 compare. In Fig. 6a. numeral 24 denotes the register circuit 42 in which connection of registers and 
comparators is so controlled as to be suited for output compare. 

In the register circuit 24 of Fig. 6A. RO. R2. R4 and R6 denote base registers and Rl. R3. R5 and R7 
denote compare registers, whereas COI. C23, C45 and C67 denote comparators. As an example 
configuration and operation of a set of output compare circuits will now be described. The registers R6 and 

35 R7 are connected together via a gate circuit 240. One of inputs of a comparator 241 is connected to the 
compare register R7, whereas the other input thereof is connected to the first read bus. An output 243 of 
the comparator 241 is connected to a set terminal S of an output flip-flop 244. The output of the fl.p-flop 
244 is connected to an outout compare output terminal 245. 

The gate circuit 240 is controlled by a zero signal line 27 extending from the processing unit 26. If the 

^0 2=ro signal line 27 becomes 1. data stored in the base register R6 is transferred to the compare register 
R7 Further, a dear terminal C of the output flip-flop 244 is connected to a zero flag line Zn - 1 for 
representing zero flag information obtained before execution of instruction. If the instruction is executed 
under the state that the Zn-1 is 1. the above described flip-flop 244 is cleared. The function of the 
processing unit complies with an instruction described in the instruction field of the micro EPROM. 

.5 Figs 6B to 6D show configurations of the processing unit 26 and the register circuit 42 used when a 

timer instruction is executed, the timer instruction was mentioned before in the term of "(1) Instruction 
specifying field" as well by referring to the list of Fig. 4. Circuit configurations implemented m the 
processing unit 26 and the register circuit 42 will now toe described by referring to Figs. 6B to 60. 

Fig 6B shows a configuration implemented when the INCCLR instruction shown in Fig. 4 has been 

60 executed. The ALU 71 connected to the first read bus 25 becomes an incrementer <INC). Further, inputs of 
the comparator CMP included in the processing unit 26 are connected to the first read tous 25 and the 
second read bus 32. At this time, hvo registers specified in the register specifying field are specified as a 
counter register Ret 29 and a constant register Roc 28. 

In the same way. Fig. 60 shows the case of the INGCMP instruction and Fig. 6D shows the case of the 

55 DECLD instruction. However. Fig. 60 and Fig. 6D will not be described further. 



(8) Input capture specifying field 
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This is a field for specifying that the processing circuit 13 should perform input capture operation. If 
input capture is specified in this field, the registers R8 to R1 1 included in the register circuit 42 are ensured 
as the input capture registers as described before in (3) and a processing circuit configuration suited for 
input capture is implemented. 

5 Fig. 6A is also a diagram showing configuration of the processing circuit 13 connected so as to be 

suited for input capture. In Fig. 6a. numeral 30 denotes the register circuit 42 at the time when the 
connection of the registers is so controlled as to be suited for input capture. Up to four input captures can 
be specified at the maximum. If this instruction is executed, input gates 301 are opened at write timing to 
registers when input capture input terminals 300 are logic 1. Contents on the write bus 31 are taken into the 

10 input capture registers R8 to Rl 1. 



INTERFACE BETWEEN MAIN PROCESSOR AND SUBPROCESSOR 

;5 Interchange of data between the CPU 2 in the main processor 5 and the subprocessor 6 is performed 
via the processor interface circuit 16 mounted in the subprocessor 6. As shown in Fig. 3. the processor 
interface circuit 16 comprises an interrupt enable flag (lEF) register 47. a first memory data (MDB1) register 
48, a first memory address buffer (MABi) register 49. a data buffer (DBF) register 50 and an address buffer 
(ABF) register 51, And the processor interface circuit 16 is controlled by a control line 17 coming from the 

20 micro EPROM. 

As interface modes to the main processor 5 shown In Fig. 2. there are three modes, i.e., (1) slave 
mode. (2) master mode, and (3) interrupt request. These three modes will now be described in detail. 



25 (1) Slave mode 

In this mode, the main processor 5 operates as the master. Data transfer between the main processor 

and the subprocessor is executed in this mode via an address bus (AB) and a data bus (DB) connected to 

the processor interface circuit 16 of Fig. 3. To be more concrete, data transfer between the CPU 2 and the 
30 registers RO to R19 included in the subprocessor 6 is performed in accordance with a read/writ signal 

(RD1/WR1) generated in the CPU 2 and the signal on the address bus (AB). 

When data are to be written into the registers RO to Rl9. write data are outputted from the CPU 2 onto 

the data bus DB, and an address corresponding to a register number is outputted onto an address bus AB. 

And a write signal (WRi) is asserted. As a result, write data is taken into the data buffer (DBF) 50, and 
as register selection information is taken into the address buffer (ABF) 51. In synchronism with the operation of 

the subprocessor channel 10. data is transferred from the above described data buffer 50 into a selected 

register. 

40 (2) fvlaster mode 

In this mode, the subprocessor 6 operates as the bus master. Under the state that the subprocessor 6 
issues a bus right request to the CPU 2 of the main processor 5 and the subprocessor 6 dominates the 
common bus 9. read/write of data from/to the RAM 3 included in the main processor 5. readout of data from 
45 the EPROM 4. and input/output of data to/from the programmable I/O 8 are executed. 

As for bus right request to the CPU 2. a bus right request signal BRO is outputted from the processor 
interface circuit 16, and an acknowledge signal BAK is outputted from the CPU 2 in response to the signal 
BRO. The right to use the bus can be used under the control of the subprocessor 6. 

The bus right request signal BRO supplied from the subprocessor is generated by executing the 
so WRSTART instruction. RDSTART instruction and the REF instruction included in the memory access 
instructions described by referring to Fig. 4, Data access in this mode will hereafter be described in detail 
by referring to Fig. 3 and a status transition diagram of a memory access control circuit shown in Rg. 7. 

In an idle state (SO), only the WRSET instruction. RDSTART instruction and REF instruction among the 
memory access instructions shown in Fig. 4 are accepted, and transition to other states becomes possible. 
55 If the WRSET instruction is executed, data of the specified register Rd or numerical data is transferred to a 
second memory data buffer {MDB2) 53 of the subprocessor 6 via the first read bus 25. the ALU 71 and the 
write bus 31. and is further transferred to the first memory data buffer (MD81) 48 of the processor interface 
circuit 16 via a memory access bus 55. The state is then shifted to "Command wait 1" (SI). 
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in the state Si. only the WRSTART instruction, and the REF instruction are accepted. If the WRSTART 
instruction is executed under this state, data of a register Ra in which a memory address is stored or 
numerical data is transferred to a second memory address buffer (MAB2) via the first read bus 25, the ALU 
71 and the write bus 31. and is further transferred to the first memory address buffer (MAB1) 49 via the 
5 memory access bus 55. At this time, the bus right request signal BRQ is outputted from the processor 
interlace ciruit 16. and the state is shifted to "Write wait" (S2). 

Under this state, the bus acknowledge signal BAK which is an answer signal returned from the main 
CPU is waited. If the acknowledge signal BAK is asserted, the state is shifted to "Write" (S3). 

in the "Write" state (S3), contents of the first memory data buffer (MDBi) are outputted onto the data 
70 bus DB. and contents of the first memory address buffer (MABl) 49 are outputted onto the address bus AB. 
In addition, a write signal {WR2) is outputted. After writing has been finished.the idle state (SO) is restored. 

If the RDSTART instruction is executed in the idle state (SO), data of a register, in which a memory 
address to be read out is stored, is transferred to the first memory address buffer 49 via the second 
memory address buffer 54. In addition, the bus right request signal BRQ is outputted. and the state is 
J5 shifted to "Read wait" {S4). 

If the acknowledge signal BAK is present in this state, contents of the first memory address buffer 49 
are outputted onto the address bus AB. and a read signal (RD2) is outputted. Data is read out into the first 
memory data buffer 48 via the data bus (S5). The state is then shifted to "Command wait 2" (S6). 

In "Command wait 2" state (S6). the RDGET instruction. WRSTART instruction and REF instruction are 
20 accepted- The RDGET instruction is an instruction for transferring data from the first memory data buffer 48 
to a specified register. As described before, the WRSTART instruction is an instruction for writing data from 
the second memory data buffer 53 into a specified memory address in a memory included in the mam 
processor or a memory disposed outside the chip, if the RDSTART instruction and the RDGET instruction 
are executed in succession, therefore, contents of the memory are taken into the register of the 
25 subprocessor 6. If the RDSTART instruction and the WRSTART instruction are executed in succession, data 
is directly transferred from a memory to another memory. 

Execution of the REF instruction is possible only in the idle state (SO), command wait i state (Si) and 
command wait 2 state (S6). in respective cases, the bus right request signal BRQ is outputted. and the 
state IS shifted to "Refresh wait 0 to 2" (S8 to SiO). 
30 If the acknowledge signal BAK is asseaed m the refresh wait state, a signal required to refresh a 

dynamic RAM is outputted to the outside of the semiconductor integrated circuit, the state assumed before 
shifting to the refresh wait 0 to 2 states (S8 to SiO) .s performed is restored. If the WRSET instruction .s 
executed in the refresh wail 0 (S9). however, the state is shifted to the refresh wait I state (S8). After the 
refresh has been finished, the state is shifted to the command wait i state (Si). 
35 Further, if the RDGET instruction is executed in the refresh wail 2 state (SIO). the state is shifted to 

"refresh wait 0" (S9). Atter the refresh has been finished, the idle state is restored. 

" if execution of a memory access instruction heretofore described is successful and shift to the next 
state has been performed, the zero flag ZF within the status register SR 70 as shown in Fig. 3 is set C^n^ 
If shirt to the next state could not be performed, the zero flag ZF is cleared ("0"). By producing such a 
40 program that the zero flag ZF atter execution of the instruction is confirmed and the same instruction is 
executed repetitively until the relation ZF = l is satisfied, reliable memory access can be performed. 



(3) Interrupt request 

^5 

This is a mode for generating an interrupt request to be supplied from the subprocessor 6 to the mam 
processor 5. An interrupt status flag (ISF) 56 shown in Fig. 3 comprises an 8-bit flag, and it can be set or 
cleared by an instruction of the subprocessor 6. That is to say. the interrupt status flag 56 can be specified 
in the port specifying field of a microinstruction and can be manipulated by the same handling as that of the 

50 I/O port. The output of the interrupt status flag 55 is connected to the interrupt enable flag (lEF) 47 disposed 
within the main processor interface circuit 16 via wiring 57. Respective bits of this interrupt enable flag (lEF) 
47 correspond to respective bits of the interrupt status flag 56. 

In case the bit of the interrupt status flag (iSF) 56 is set and the interrupt enable flag <IEF) 47 is set. an 
interrupt request IRQ to the CPU 2 is generated. The interrupt enable flag 47 is connected to the data bus 

55 DB, and its write and read operation can be performed from the main processor 5. 

INTERFACE BETWEEN SUBPROCESSORS AND BETWEEN PORT AND SUBPROCESSOR 
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Interface between the main processor 5 and the subprocessor 6 has heretofore been described. As 
described with reference to Fig. l. the present subprocessor 6 comprises the subprocessor channel A lOa 
and the subprocessor channel B lOb having the same configuration. In order to perform communication 
between these subprocessor channels, the interchannel interface circuit 19 is provided. The interchannel 

5. interface circuit 19 compnses an 8-bit semaphore flag (S) and is connected to both the subprocessor 
channel A lOa and the subprocessor channel B tOb. Therefore, respective channels can gain access to the 
semaphore flag (S) in common. Selection and manipulation of the semaphore flag is specified by the port 
specifying field of the microinstruction. The semaphore flag (S) can be set and cleared by the write 
manipulation and it is a flag with readout clear. 

to The port interface circuit 15 of Fig, 3 is an interface circuit between the subprocessor channel 10 and 
the interchannel interface circuit i9 comprising the I/O circuit (I/O) 18. the interrupt status flag (ISF) 56 and 
the semaphore flag (S). the I/O circuit 18 comprises a 1 6-bit I/O port and can communicate with the outside 
of the semiconductor integrated circuit via a terminal 67. All of the above described 1/0 port 18. the interrupt 
status flag 56 and the semaphore flag 19 are handled as ports taking one bit as unit. By specification in the 

15 above described port specifying field of the micro EPROM 1 1 , three ports can be simultaneously selected 
as I/O port (Po). output pon (Pi) and input port (Pck) to perform read/write operation. 

The port interface circuit 15 is connected to the status register (SR) 70 via a status register output line 
68 and supplied with information of the carry flag (OF) and zero flag (ZF) stored in the status register 70. 
The port data line 69 is inputted to the arithmetic and logic unit (ARtJ) 71 and the address control circuit 21 

20 via the carry input selector 38. In the address control circuit 21. a signal on the port data line 69 is used as 
one of branch conditions. The port interface circuit 15 is coupled to the above described ports by a Po 
signal line 59. a Pi signal line 58. a Pck signal line 60. a Po selection line 62. a Pi selection line 61 and a 
Pck selection line 63. It is possible to specify I/O to a port selected by the Po selection line 62 and perfornn 
data output to the port and data input from the port via the Po signal line 59. It is possible to specify only 

25 output to a port selected by the Pt selection line 61. and data is outputted to the port via the Pi signal line 
58. It is possible to specify only input to a port selected by the Pck selection line 63. and data from the port 
is inputted via the Pck signal line 60. this Pck signal is used for skip control of an instruction. In addition to 
port functions specified by the Pc selection line 62. Pi selection line 61 and Pck selection line 63 heretofore 
described, there are output compare function and input capture function. However, they function as 

30 described before. 



ADDRESS REGISTER AND STATUS REGISTER 

35 The address register circuit 20 of the subprocessor channel 10 shown in the present embodiment 

comprises 8 address registers having identical configuration. Address information of the micro EPROM 11 
is stored in each address register. Further, the status register circuit (SR) 70 also comprises 8 status 
registers having identical configuration. 

Fig. 8 shows an example of configuration of the address register circuit 20, the register circuit (SR) 70 

40 and their peripheral circuit. The address register circuit 20 comprises address registers ARO to AR7. an 
address register output selector 73 for selecting one of respective output lines 72. an address register input 
multiplexer 75 connected to an output line 74 of the address control circuit 21. and address register input 
lines 76 for transferring the output of the address register input multiplexer 75 to the address registers ARO 
to AR7. Further, the status register circuit 70 comprises status registers SRO to SR7. a status register 

45 output selector 78 for selecting one of respective output lines 77, a status register Input multiplexer 80 
having as its input line a status signal line 70 outputted from the processing unit 26. and status register 
input lines 81 for transferring the output of the status register input multiplexer 80 to any one of the status 
registers SRO to SR7. 

Control signals of the above described address register output selector 73. the address register input 
50 multiplexer 75. the status register output selector 78 and the status register input multiplexer 80 are 
generated in the control PLA 14. and are used to control respective units via an address register output 
control line 82. an address register input control line 83, a status register output control line 84 and a status 
register input control line 85. Assuming that an address register ARi is selected out of eight address 
registers AR and a status register SRI is selected out of eight status registers SR. a series of operation will 
55 now be described. 

© Selection information of ARi is. outputted from the control PLA 14- onto the address register output 
control line 82. Data of the micro EPROM 1 1 is read out by using contents of the ARi as the address, and 
that data is transferred to the address control circuit 21, the processing control circuit 22 and the register 
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15 



20 



control circuit 23. 

@ The address control circuit 21. the processing control circuit 22 and the register control circuit 23 
decode data respectively relating to address control, processing control and register control mciuaed m data 
of the micro EPROM. As a result, generation of control signals required for processing control of .he 
processing unit 26 and selection of a register are performed. 

@ Contents of a source register are read out. Selection information of SRI is outputted fronn the 
control PLA 14 onto the status register output control line 84. By using the carry flag and/or the zero flag 
contained in the SRi, processing is executed. 

® Selection signals SRi and ARi are outputted from the control PLA 14 onto the status register input 
control line 85 and the address register input control line 83. respectively. The result of processing is 
written into the destination register. New status register data generated as a result of processing is taken 
into the SRi and the next address is taken into the ARi. A series of operation is thus finished. 

In the above described series of operation ® to @. selection of the address register ARi and the 
status register SRi is performed by the control Pt-A 14. By constructing the control PLA so that the pair of 
address register and status register may be successively changed and executed, therefore, up to 8 
independent programs of the micro EPROI^ can be executed. The control PLA 14 is controlled by a reset 
signal line 94 and an event control line lOO connected to an event driven control circuit 99. These control 
lines will be described later. 

As a first example of control performed by the control PLA 14. it is now assumed that pairs of address 
registers and status registers and orders of these pairs are prescribed as follows. 



ARO-SRO * ARI -SRI - AR2'SR2 

25 AR3-SR3 

+ + 
AR6-SR6 AR5-SR5 - AR4-SR4 

30 

In case of this example, one cycle is executed in time required for executing the above described 
series of operation ®. to ®. i.e.. in time equivalent to 8 times the microinstruction execution time. The 
same pair of address register and status register is restored. ^ 
Fig 9A shows a second example of control performed by the control PLA 14. In this example, the 

35 above descnbed series of operation is represented by a state Si. One cycle comprises 16 states, i.e.. So to 
S.s In each state, the illustrated pair of address register and status register is selected and executed, in 
Fig 9A FO to F7 represent functions executed by using ARO'SRO to AR7'SR7. respectively. Each function 
is implemented by a combination of instructions shown in Fig. 4. i.e.. a program. In case of the example 
shown in Fig 9A. the function FO is executed four times in a cycle time tcy. That is to say. 4 

^0 microinstructions are executed in the cycle time tcy. Each of the functions Fl and F2 is executed once in 
the cycle time tcy. Each of the functions F3. F4. F5. F6 and F7 is executed twice. Therefore, the execution 
cycle of each function can be represented as follows. 
FO: tcy/4 
F 1 , F2: tcy 

■'5 F3 to F7' tcy/2 

The second control example of the control PLA has heretofore been described. By changing data of the 
control PLA. however, an arbitrary combination can be implemented. It is also possible to implement kiw- 
speed function, medium-speed function and high-speed function mixedly. Further, by using a contro PLA 
comprised of electrically writable EPROM devices. It becomes possible to freely reconstruct the control PLA 

5° in the user field in the same way as the micro EPROM. 

Fig 98 Shows a third example of control performed by the control PLA. In this example, one cycle 
comprises 5 states So to S*. Event driven function is assigned to the state S*. The term "event driven 
means that three terminals (le 0. le 1. le 2) included in the terminal 67 as shown in Fig. 8 are used as event 
input terminals having priority orders and the control PLA is controlled via the I/O circuit 18 an event driven 

55 input line 66 the event driven control circuit 99 included in the port interface circuit 15, and the even 
control line lOO. Thereby, functions corresponding to the input terminals le 0. le l and le 2. '-e.. pa-rs of 
address registers and status registers are selected. In the example of Fig. 98. F4 (AR4 SR4). 
(AR5-SR5) F6 (AR6-SR6) and F7 (AR7*SR7) are assigned as the event driven function. Assuming now 
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that priority orders of inputs from the input terminals le 0. le 1 and le 2 are prescribed as le 0 > le 1 > le 2 
(i.e.. the input from the le 0 has the highest priority), functions F4 to F7 can be selected as shown in TABLE 
5. 

TABLE 5 



JO 



15 



20 



25 



30 



35 



40 



4S 



SO 



55 



le 0 


te 1 


le 2 


Function 


0 


0 


0 


F4 


0 


0 


1 


F5 


0 


1 


X 


F6 


1 


X 


X 


F7 



In this table, mark x means "don't care", i.e.. the input represented by mark x is disregarded. 

Fig. 10 shows an example of configuration of the control PLA 14 and the event driven control circuit 99 
shown in Fig. 8. This control PLA 14 comprises a logic array structure (AND plane, OR plane). To be more 
concrete the control PLA 14 comprises an AND (logical product) plane 87. an output line (product term 
line) 88 of the AND plane 87. an OR (logical sum) plane 89. a feedback latch (LF) 90 connected to the 
output of the OR plane 89 via a feedback latch input line 98. an input latch (LI) 92 connected to the 
feedback latch 90 via a feedback line 95, and an output circuit 93 connected to the OR plane 89. The AND 
plane 87 and the OR plane 89 of the PLA comprise electrically writable non-volatile semiconductor memory 
devices. Contents can be written from the outside of the microcomputer chip into the AND plane 87 and the 

OR plane 89. ■ . 

Outputs of the output circuit 93 are the address register output control line 82. the address register 
input control line 83. the status register output control line 84 and the status register input control line 85. 
Inputs of the input latch 92 are connected to a reset signal line 94 for supplying an initializing signal and an 
event control line 100 coming from a priority encoder 101 included in the event driven control circuit 99. 

The event driven control circuit 99 comprises event latches 102a. 102b and 102c connected to the 
above described priority encoder 101 and the I/O circuit 18. Set terminals of the event latches i02a. i02b 
and 102c are connected to the I/O circuit 18 via event driven input lines 66. Each of the event latch s l02a. 
102b and i02c has a clear terminal C so that the latch may be cleared by an instruction of the 

subprocessor 6. . . ,_ os* 

In the present configuration example, the feedback line 95 comprises six lines, and up to 64 ( - 2 ) 
states at the maximum can be programmed. A control output line 96 from the OR plane 89 comprises 4 
lines and transfers pair selection information of address registers ARC to AR7 and status registers SO to S7 
relating to function to be executed to the output circuit 93. On the basis of this information, the output circuit 
93 performs timing control required for a series of control. 

Figs 11 A and liB show PLA data respectively corresponding to the PLA control examples described 
by referring to Figs. 9A and 9B. respectively. In Figs. 11 A and 11 B. "EV" represents contents of an event 
input "FB" state information inputted to the AND plane 87 via the feedback line 95. "next state" next state 
information outputted from the OR plane 89 onto the feedback latch input line 98, and "control" function 
executed as a result of control performed by the control PLA 14. 

Operation of the control PLA 14 in the examples of Figs. 9A and 98 will now be described by referring 
to Figs. 10, 11 A and 11 B. , ^ ^ 

In the example of Fig. 9A, event function is not defined. As shown in Fig. 11 A. therefore, the event input 

Ev is marked with x ("don't care") in all states (SO to SI 5). 

When the output of the input latch 92 contains information of Sj 0 = 0 to 63). i.e.. when the state 
executed at the AND plane 87 is S,. information S,., of the next state is outputted onto the feedback latch 
input line 98. Further, a selection signal of the ARI'SRi pair (Fi) relating to the function executed at the state 
Si is outputted onto the control output latch input line 99. . ^ . 

With reference to Fig. 9A. SO is inputted to the AND plane 87 while the reset signal 94 is being 
inputted When the reset is cancelled, operation is started from this state SO. That is to say. Si is outputted 
from the OR plane 89 onto the input line 98 as the next state, and latched in the feedback latch 90. As the 
control output FO is outputted. When a series of processing relating to FO has been finished, the next state 
information Si is transferred from the feedback latch 90 to the input latch 92 to become input information of 
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the AND plane 87. Operation heretofore described is repeated. If SO is defined as the next state infornnation 
when the input information to the AND plane isj5l5. operation is repetitively executed in the loop as shown 
tn Fig. 9A- 

In the example of Fig. 9B. event function is assigned to state S4. At the state S4 succeeding the 
5 execution of the S3 state, a function is selected and executed depending upon the state of the event input 
EV. That is to say. functions F4. F5. F6 and F7 are selected and executed respectively when Ev = Ev 3. Ev 
= Ev 2. Ev = Ev 1 and Ev = Ev 0. That is to say, the S4 state is described as four states comprising 
Ev3'S4. Ev2*S4. EWS4 and ER0'S4. where represents logical product. 

if SO is described as the next state succeeding the above described tour states, the processing returns 
JO to the SO state after the event function has been executed. The loop operation is thus repeated. 

Fig. 12 shows a timing chart in case the event input is supplied in the order represented as Ie2 — lei 
(where priority is represented as Ie2 < lei). In the state before the event input is inputted. F4 included in 
the functions F4 to F7 assigned as event function is executed. A loop is formed as FO — F1 F2 ^ F3 — 
F4 (® in Fig. 12). 

/5 Assuming now that the event input Ie2 changes to *M" at illustrated timing (a), the F4 function which is 

being executed is interrupted and execution of F5 is then started. A loop is formed as FO -* F1 — F2 ^ F3 
- F5 (© in Fig. 12). 

If lei changes to "1" at illustrated timing (b) before execution of ^he F5 function is finished, execution of 
F5 is also interrupted and execution of F6 is started. In case no input has higher priority than that of tel. 
20 processing is continued in the loop represented as FO — Fl — F2 — F3 — F6 until processing of the F6 
function is finished, i.e., until the program itself constituting the F6 function clears an event latch 1 (© in 
Fig. 12). 

If the event latch 1 is cleared by the F6 program at illustrated timing (c). processing of F5 which has 
been interrupted is restarted (® in Fig. 12). and an event latch 2 is cleared by the program of F5. 
25 Processing is thus finished (d). 

If the event latch 2 is cleared, execution of F4 is restarted. 

In the example shown in Fig. 12. the case where event inputs are generated in order of low priority has 
been described. In case where an input having lower priority is inputted later, however, processing of a 
function having low priority is started after processing of a function having high priority has been finished. 

30 

PIPELINE CONTROL 

A series of operation performed by the selected address register ARi and status register SRi as 
35 described before by referring to Fig. 8. i.e.. (T) reading information from the micro EPROM, @ decoding. (3) 
reading source register and processing, and (3) writing information into the destination register can 
undergo pipeline control by inserting latches between circuits executing respective functions. High speed 
multifunction control by using piepline control will hereafter be described. 

Fig. 13 shows a second configuration example of a control circuit which is based on Fig. 8 and which 
40 allows pipeline control. The difference of configuration of Fig. 13 from that of Fig. 8 will now be described. 

(1) The processing control circuit 22 disposed between the micro EPROM 11 and the processing unit 
26 is divided into a decoder 22a and a control circuit 22b. The register control circuit 23 disposed between 
the micro EPROM 11 and the register circuit 42 is divided into a decoder 23a and a control circuit 23b. In 
addition, latches 103. 104. 105 and 106 are disposed at positions illustrated in Fig. 13. 
-5 (2) A latch 107 is disposed between the processing unit 26 and the write bus 31. And a latch 108 is 

disposed between the processing unit 26 and the status signal line 79. 

(3) The address control circuit 21 comprises a first delay buffer 109. a second delay buffer 110. a 
third delay buffer 111. a branch control circuit 112 controlled by the status signal line 79 and the port data 
line 69, and a next address selection circuit 113. The output line 74 of the address control circuit 21 is 
.50 inputted to the address register circuit 20. 

In the above described circuit configuration, a series of operation is executed as follows. 

(A) : TO cycle 

55 

Selection information of address register Ari is outputted from the control PLA 14 onto the address 
register output control line 82. By using contents of the ARi as the address, data in the micro EPROM 1 1 is 
read out. That data is taken into the latches 103 and 105 and the first delay buffer 109. 

15 
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(B) : T1 cycle 

Contents of the latches 103 and 105 are decoded by the decoder circuits 22a and 23a. The contents 
thus decoded are taken into the latches 104 and 106. respectively. In addition, data is transferred from the 
5 first delay buffer 109 to the second delay buffer 1 10. 

(C) : T2 cycle 

;o On the basis of contents of the latches 104 and 106. respectively, the control circuits 22b and 23b 
generate control signals and perform reading the source register and outputting selection infornnation from 
the control PLA 14 onto the status register output control line 84. As a result, processing is executed in the 
processing unit 26 by using the carry flag CF and the zero flag ZF. And the result is taken into the* latches 
107 and 108. Further, data is transferred from the second delay buffer 110 to the third delay buffer ill. 

/5 And data of the latch 106 is transferred to a latch 114. 



(D) : T3 cycle 

20 Via the write bus 31. contents of the latch 107 are written into a destination register selected on the 
basis of data of the latch 114. In addition, status register selection information is generated on the status 
register input control line 85. Status register data generated as a result of processing is taken into the status 
register SRi. Further, the next address is selected on the basis of information of the next address control 
field of the micro EPROM already taken into the third delay buffer. In accordance with a signal supplied 

25 from the control PLA 14 onto the address register input control line 83. the next address is taken into the 
address register ARi. A series of operation is thus finished. 

A series of pipeline control heretofore described becomes possible by using a delay latch in the output 
circuit 93 included in the control PLA 14 as shown in Fig. 10 and by configuring the output circuit 93 as 
shown in Fig. 14A. That is to say. latch circuits 116. 117 and 118 initially cleared by the. reset signal 94 are 

30 inserted between the control output line 96 extending from the OR plane 89 of the PLA and outputs 82. 83. 
84 and 85 of the output circuit 93. Respective latch circuits successively latch the input signal on the basis 
of the clock signal, and operate as shown in Fig. 14B. 

In Fig. 14B. A to D represent a series of functions processed in cycles TO to T3. In the TO cycle, 
selection information AROi of the address register ARi is outputted onto the address register output control 

35 line 82 via an output timing circuit 115 on the basis of a control output signal Fi (®) outputted onto the 
control output line 96 of the PLA. 

On the other hand, a signal on the control output line 96 is inputted to the latch circuit 116. Further, the 
output of the latch circuit 116 is inputted to the latch circuit 117. Therefore, the output of the latch circuit 
1 17 is delayed by two cycles. In the T2 cycle, a selection signal SROi of the status register SRi is outputted 

40 onto the status register output control line 84 (Q)). 

Further, the output of the latch circuit 117 is delayed by one cycle in the latch circuit 11 8. In the T3 
cycle, an address register input control signal ARIi (®) and a status register input control signal SRIi ((D) 
are outputted. And a series of operation for executing one word of a microinstruction constituting a specified 
function Fi. 

45 Fig. 15 shows an example obtained by applying pipeline control to the control example shown in Figs. 
9A and 11A. In states So to Sts. respective functions Fi (FO to F7) to be executed are outputted, 
respectively (0). In accordance with the signal Fi. control ® to © is performed by the circuit of Fig. 14A. 
By the control heretofore described, a series of control A to 0 as illustrated is executed with respect to each 
of the functions FO to F7. That is to say. processing A to D of some function is executed in all of th states 

50 So to Si 5. illustrated control b'. c' and d' is not executed in the first loop started from the reset, but 
executed in the second and succeeding loops. 

In the example heretofore described by referring to Figs. 13. 14A. 148 and 15. the number of the 
control status registers SR 70 is equivalent to the number of address latches, i.e., 8. The original object of 
providing status registers is to hold information such as zero and carry generated in processing executed at 

55 a certain instruction step so that such information may be used at a different instruction step which will be 
executed later. In a processor such as the subprocessor described in the present embodiment in which 
execution of one step of a microinstruction terminates generation of branch condition and generation of 
branch address, therefore, status holding for a long time for the purpose of condition branch becomes 
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unnecessary provided that the status output is held for the execution interval of the one step. That is to say, 
as many status registers as address latches become unnecessary. It is also possible to provide only one 
latch capable of holding the status output during only the instruciion cycle. In this case, complicated 
processing such as double length processing implemented by using an instruction comprising a plurality of 
steps can be implemented as follows although the execution efficiency is worsened. For example, in case it 
IS desired that carry information generated as a result of execution at a first instruction step is used as 
increment information at the next instruction step, it is attained by producing such a program that 1 
instruction is described at the destination specified when carry = i as a result of processing performed at 
the first instruction step whereas to instruction is described at the destination specified when carry = 0. 

Fig. 16 shows the configuration of a peripheral circuit of the control PLA for performing initial value 
setting of the address register AR and reset control of the subprocessor 6. The control PLA 14 of Fig. 16 is 
obtained by adding an initial address control line 1 19 to the control PLA 14 of Fig. 10 having the output 
circuit 93 described before by referring to Fig. 14A. 

As described before by referring to Figs. 8 and 10. the address register output control line 83 included 
in the output of the output circuit 93 controls the address register input multiplexer 75 for selecting inputs 
supplied to the address registers AflO to AR7. 

In Fig. 16. the following circuit is added to the above described circuit. The signal on the initial address 
control line 119 is successively delayed by 3-stage latch circuits 120. 121 and 122. The output of the last 
stage latch circuit 122 is connected to one input of the first logical sum (OR) circuit 123. The other input of 
the OR circuit 123 is connected to the output of a comparator 124 which is controlled by a function reset 
enable bit (FRE) stored in a command register 125. Inputs of the comparator 124 are the address register 
input control line 83 and a function number bit (FN) stored in the command register 125. The address 
register output control line 83 is connected to an'initial address generation circuit 126 as well. The output of 
the initial address generation circuit 126 is inputted to a selector circuit 127 controlled by the OR circuit 
123. The other input of the selector circuit 127 is connected to the output 74 of the address control circuit 
21. 

Initial value setting of the address register AR in the circuit configuration heretofore described, i.e.. 
setting of initial address Al; of the micro EPROM storing therein the program of function Fi and reset control 
will now be described by referring to Figs. 16 and 17. As compared with Fig. 11 A. information of an initial 
value setting specifying bit (I) for supplying information onto the initial address control line 119 is added in 
Fig. 17, Description of in Fig. 17 is the same as that of Fig. 11 A with the exception of prescription I = 0. 

In both Fig. II and Fig. 17. Fi is described in the control field. In reality, however. 3-bit numerical data 
"i" is written. That is to say. if I - 1 and Fi is described in the control field. 3-bit data "I" is set in 3 low-order 
bits of the address register AH-, as initial address. Logic "0"s are set into all of high-order bits excepting 3 
low-order bits. 

In Fig. 16. the output (I) on the initial address control line 119 is outputted at the same timing as that of 
the output on the control output line 96. The output (I) on the initial address control line 1 19 is delayed by 3 
cycles by the latch circuits 120. 121 and 122. The output on the control output line is delayed by 3 cycles 
by the latch circuits 116. 117 and 118. Information of the initial value setting specifying bit (I) functions as 
the selection signal of the selector circuit 127 via the OR circuit 123. On the other hand, the numerical value 
"i" is outputted onto the address register input control line 83. The numerical value "i*" functions as a 
control signal of the address register input multiplexer 75 and becomes the input data of the initial address 
generation circuit 126. The initial address generation circuit 126 functions to place "i" in 3 low-order bits 
and "O" in other high-order bits to generate an initial address. 

In case of the initial value setting specifying bit (I), = 0. the address control circuit output line 74 is 
selected in the selector circuit 127. Data read out from the micro EPROM is thus inputted to the address 
register ARj via the address register input multiplexer 75. 

In case I = l. the output of the initial address generation circuit 126. i.e.. the initial address is selected 
in the selector circuit 127 and is inputted to the address register ARt via the address register input 
multiplexer 75. In Fig. 17. operation is started from a SO' state by the reset start. In states SO' to S7', the 
initial address (low-order data: 0 to 7. high-order data: 0) is supplied successively to address registers FO to 
F7 (© in Fig. 17). Thereafter, the operation described before by referring to Fig. 11A (<D in Fig. 17) is 
started, and then the loop operation is performed. 

The command register (RCMND) 125 is a register for performing the reset control of the subprocessor 
6 and has 7-bit configuration as shown below. 
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b* 
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bo 


RCMND 


RA 


RB 


FREA 


FREB 


FN 



Meaning of respective portions are as follows. 
RA: Totally reset subprocessor channel A 
RB: Totally reset subprocessor channel B 

FREA: Reset the function described in FN among functions of the subprocessor channel A 
FREB: Reset the function described in FN among functions of the subprocessor channel B 
FN: Describe the function number (Fi) when FREA = 1 or FREB = 1 

The command register 125 is disposed in the memory space of the CPU 2 shown in Fig. 2. The CPU 2 
can gain access to the command register 125. in Fig. 16. a command register 125 relating to control of one 
channel is shown. However, bit R of Fig; 16 corresponds to the above described RA or RB. and FRE of Fig. 
16 corresponds to the above described FREA or FREB. 

If the bit R of the command register 125 is set at "1". that Inforniation is supplied to the input latch 92 
via a second logical sum (OR) circuit 128 and a reset signal fine 94' as a reset signal. The whole control 
PLA 14 is thus controlled to assume the reset state. That is to say. the whole control PLA 14 is controlled 
equally to the case where "1" is supplied to the reset signal tine 94. If the R bit is thereafter set at "O". the 
reset is cancelled, and control is restarted from the initial state SO shown in Fig. 17. 

If the function number Fi is set into the FN bits (3 bits) of the command register 125 and the relation 
that FRE bit = 1 is satisfied, the comparator 124 is enabled. At timing where the value of the FN bit 
becomes equal to the value of the address register input control line 83. "1" is outputted from the 
comparator 124 to control the selector circuit 127 via the OR circuit 123. From the selector circuit 127, a 
value obtained by modifying the output of the initial address generation circuit 126. i.e.. the value of the 
above described address register input control line 83 is inputted to the address register ARj via the 
address register input multiplexer 75. As a result, only function Fi specified in the FN bits of the command 
register 125 is reset. As a result of relation FRE bit = 0. microprogram of the function Fi is restarted from 
the initial address. At this time, functions other than the function Fi are not affected, and the program is 
continued. 



35 



PROGRAMMABLE I/O 



The programmable input/output port (programmable I/O) 8 shown in Fig. 2 will now be described. Fig. 
18 shows configuration 130 of the programmable I/O 8 corresponding to one bit. As described befor in the 
item of port specifying field of the micro EPROM, the programmable I/O comprises a plurality of I/O bits as 
shown in Fig. 18 and is specified by the information of the port specifying field. 
''^ The programmable I/O bit 130 comprises an output circuit 132 and an input circuit 131. The output 

circuit 132 is connected to the terminal 67 via terminal wiring 133 and has an output line (DEO) 136 
extending to the data bus and an output line (SPO) 137 extending to the subprocessor. The input circuit 131 
is connected to the terminar67 via the terminal wiring 133 and has an input line (DBI) 134 extending to the 
data bus and an input line (SPI) 135 extending to the subprocessor. 

The output circuit 132 comprises a selector 139 for selecting the DBO 136 and SPO 137. a latch output 
circuit 140 controlled by the output of the selector 139. a next level output circuit 141 supplied with the SPO 
137 as input, an inversion output circuit 142. an output selector 146 so supplied with output lines 143, 144 
and 145 respectively from the above described latch output circuit 140, next level output circuit 141 and 
inversion output circuit 142 as to select either one of those output lines 143. 144 and 145. a data direction 
register (DDR) 147. and an output buffer 148 so controlled by the data direction register (DDR) 147 as to 
output data onto terminal wiring 133. 

Further, the selector 139 is connected to a non-volatile switch circuit (EPSW1) 149 using EPROM 
devices. Further, the output selector 146, the DDR 147. the latch output circuit 140. the next level output 
circuit 141 and the inversion output circuit 142 are connected to a non-volatile switch circuit (EPSW2) 150. 

The input circuit 131 comprises an input buffer 138 connected to the terminal wiring 133. a first input 
selector 152 having an output line 151 of the input buffer 138 and th above described output lines 143. 
144 and 145 as its input, a second input selector 153 having the output line 151 of the input buffer 138 and 
the above described output lines 143. 144 and 145 as its input, a both edges detection circuit 155 supplied 
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with an output 154 of the firsi input selector 152 at its input, a positive edge detection circuit 156 supplied 
with the output 154 of the first input selector 152 at its input, a negative edge detection circuit 157 supplied 
with the output 154 of the first input selector 152 at its input, and a subprocessor input selector 158 
supplied with the output 154 of the first input selector and outputs of the detection circuit 155, the positive 
5 edge detection circuit 156 and the negative edge detection circuit 157. 

Selectors 153. 152 and 158 are connected to non-volatile switch circuits (EPSW3 and EPSW4) 159 and 
160. Functions of principal circuits will hereafter be described. 



JO Latch output circuit 140: 

It latches write data supplied from either tfie output line 136 of the data bus included in the connmon 
bus 9 as shown in Fig. 2 or the output data line 137 coming from the subprocessor 6. 

15 

Next level output circuit 141: 

It comprises first end second latch circuits. Data of a first latch written via the data bus is transferred to 
a second latch connected to the output line 144 by an output signal from the subprocessor. 

20 

Inversion output circuit 142: 

It performs inversion operation upon the output signal of the subprocessor. 

25 

Both edge detection circuit: 

It detects a rising edge or a falling edge of a signal inputted from the terminal 67 and sets a flip-flop. If 
30 readout from the subprocessor is performed, contents of the flip-fiop are outputted and the flip-flop is 
cleared. 



Positive edge detection circuit 156: 

OS 

It detects a rising edge of a signal inputted from the terminal 67. thereby a flip-flop being set. If readout 
from the subprocessor is performed, contents of the flip-flop are outputted and the flip-flop is cleared. 



JO Negative edge detection circuit 157: 

It detects a falling edge of a signal inputted from the terminal 67. thereby a flip-flop being set. If readout 
from the subprocessor is performed, contents of the flip-flop are outputted and the flip-flop is cleared. 

EPSWl: 

It defines whether the input of the latch output circuit 140 should be coupled to the data bus or should 
be coupled to the subprocessor output. 

50 

EPSW2: 

It is a circuit for defining the output function and it can define the following functions. 
55 © It supplies initial data to the latch output circuit 140. the next level output circuit 141 and the 

invesion output circuit 142 via an initial data line 161. 

@ It defines which output should be selected from outputs of the latch output circuit 140. the next 
level output circuit 141 and the inversion output circuit 142 by using a selection line 162. 
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(3) It supplies initial data to the data direction register (DDR) via an initial direction control line i63 to 
define the initial data direction of the terminal 67 (input or output). The above described DDR is connected 
to the data bus as well, and it is also possible to reset data from the main processor on occasion. 

5 

EPSW3: 

It defines whether the input of the data bus should be the input from the terminal 67, any one of outputs 
of the latch output circuit 140. the next level output circuit 141 and the inversion output circuit 142. or 
to inhibited. 



EPSW4: 

IS It is a circuit for defining the input function to the subprocessor, and it can define the following 
functions. 

© By using an input data selection line 176. the EPSW4 defines whether the input data source of 
the subprocessor should be the input from the terminal 67. the output of the latch output circuit, the output 
of the next level output circuit 141 or the output of the inversion output circuit 142. 
20 (D By using an input function selection line 164. the EPSW4 defines whether the input function to the 

subprocessor should be both edges detection, positive edge detection, negative edge detection or level 
input. 

By initially programming the non-volatile switch circuits (EPSW l to 4) heretofore described, various 
desired functions can be realized. 

25 Figs. 19A and 19B show examples of configuration of a non-volatiie switch circuit. A first example 
shown in Fig. 19 comprises PMOS transistors 165 and 166, NIV10S transistors 167 and 168. an NMOS 
transistor 171 for yielding test data, and an EPROfVl circuit 184 including an NMOS transistor 169 having 
high withdtanding voltage, an EPROM device 170 and an EPROfVt write circuit 172. Source electrodes of 
the PMOS 165 and the PMOS 166 are connected to a power supply line 174. Numeral 175 denotes a 

30 ground line. In each of a transistor pair comprising the PMOS 165 and the Nf^OS 167 and another 
transistor pair comprising the PMOS 166 and the NMOS 168. drain electrodes of both transistors are 
coupled together and gate electrodes are coupled to identical gate wiring, resulting in a complennentary 
structure. Further, the output terminal of one transistor pair is coupled to the input terminal of the other 
transistor pair and the output terminal of the other transistor pair is coupled to the input terminal of one 

35 transistor pair, resulting in cross coupling. 

Drain wiring of the transistor pair comprising the PMOS 165 and the NMOS 167. i.e.. wiring pulled out 
from gate wiring of the transistor pair comprising the PMOS 166 and NMOS 168 becomes an output line 
173. Further, one electrode of the NMOS transistor 171 is connected to the drain wiring of the transistor pair 
comprising the PMOS 166 and the NMOS 168. i.e.. the gate wiring of the transistor pair comprising the 

40 PMOS 165 and the NMOS 167. Test data is supplied to the cross coupled circuit via the NMOS transistor 
171. Inputs of an EPROM write circuit 172 are connected to a high voltage power supply line 180 for 
supplying write voltage (12V) and a write data line 181. Output lines of the write circuit 172, i.e.. write 
control lines 177. 178 and 179 are connected to gate electrodes and drain electrodes of the NMOS 169 
having high withstanding voltage and the EPROM device 170 to control writing information into the EPROM 

45 device 170. Input-output relationship at the time of writing, i.e., at the time when 12 V is applied to the high 
voltage power supply line 180 is shown in Table 6. 

TABLE 6 







Voltages on respective 
control lines (V) 


177 


178 


179 


Input voltage (V) 

of write data line 
181 


5 


0 


9 


12 


0 


. 0 


0 


0 
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The EPROM device used in the present embodiment is a device of ultraviolet ray erasing type. As a 
resuit cf radiation of ultraviolet rays, the threshold of the EPROM device becomes approximately 1 V. If 
writing is executed by applying voltage of 5 V to the data line 181 under the state that data are erased, the 
5 threshold cf the EPROM device rises to approximately 7 V. If the control lines 177 and 179 are supplied 
with 5 V and the control line 178 is held in the floating state excepting at the time of writing, therefore, the 
EPROfvi device 170 becomes conductive in the erase state whereas it becomes nonconductive in the write 
state. 

When the voltage of the power supply line 1 74 is changed from the voltage (0 V) equivalent to that of 
10 the ground line to 5 V in the write state, i.e.. in the nonconductive state. 5 V is outputted on the output line 
173 without fail because of the configuration heretofore described. If circuit design is so performed that 0 V 
is outputted onto the output line 173 without fail when the voltage of the power supply line 174 is changed 
from the voltage (0 V) equivalent to that of the ground line 175 to 5 V in the conduction state, therefore, it 
becomes possible to fix the voltage on the output line 173 at the time of power supply coupling depending 
t5 Upon the erase state or the write state of the above described EPROM device 170. Therefore, the PfVIOS 
165 is so set as to have lower current conduction capability than that of the PMOS 166 and the NMOS 168 
is so set as to have lower current conduction capability than that of the NMOS 167. 

The NMOS 171 is a transistor for supplying arbitrary data to the above described cross coupled circuit 
in the state that the EPROM device 170 is erased. If data is supplied to an electrode 182 and 5 V is applied 
20 to a gate electrode i83. data can be inputted to the cross coupled circuit. Even if the voltage of the gate 
electrode i83 is restored to 0 V after data has been supplied in the above described state, that value is 
held. In this case, data on the output line 173 is equivalent to data obtained by inverting data supplied via 
the NMOS 171. 

Fig. 19B shows a second configuration example of a non- volatile switch circuit. In this example, an 

25 EPROM circuit 184* having the same configuration as that of the EPROM circuit 184 described in the first 
example is inserted between the NMOS 167 and the ground line 175 of the first example. In case of this 
example, it is possible to stably fix the output 173 without setting the MOS transistors into unbalanced 
states, by bringing only one of EPROM devices 170 and 170' into the write state. In case arbitrary data is to 
be supplied to the cross coupled circuit, data can set by bringing both EPROM devices 170 and 170 in the 

30 erased state and controlling the NMOS 171* in the same way as the first example. 

Fig. 20 shows detailed configuration of the PLD 7 and the second programmable I/O port (PI/02) 199 in 
the single chip microcomputer shown in Fig. 2. The PLD 7 comprises an input selector 200. a logical 
product (AND) circuit 201. a logical sum (OR) circuit 202. an output circuit 203. an output multiplexer 205. 
and feedback wiring 204 from the output circuit 203 to the logical product circuit 201 . Among the above 

35 described components, the input selector 200. the output circuit 203 and the output multiplexer 205 are 
controlled by non-volatile switch. circuits EPSW13. EPSW14 and EPSW15 using EPROM devices as 
described by referring to Figs. 19A and 19B. 

The programmable I/O port 199 comprises five ports PDBO 191. Pi 188. P2 189. P3 190 and PDBI 192 
each having 8-bit configuration and each being connected to the 8-bit data bus DB included in the common 

•io bus. Further, each port is controlled by a selection signal SEL. a read signal RD and a write signal WR. 
Among the above described ports, three ports PO. Pi and P3 are characterized by non-volatile switch 
circuits EPSWIO. EPSW1 1 and EPSW12. respectively. By this characterization, the ports PO. Pi and P3 
are used for bilateral general-purpose I/O ports for performing data transfer between connection lines 185. 
186 and I87 for terminals and the data bus DB. In addition, the ports PO. Pi and P3 can also be used for 

45 data transfer between the connection lines 185. 186 and 187 and the above described PLD 7. 

The port Pi can perform data inputting to the PLD 7 via an output line 194. The port P2 can perform 
data inputting to the PLD 7 via an output line 195 and data outputting from the PLD 7 via an input line 196. 
The port P3 can perform data outputting to the PLD 7 via an input line 197. The ports PDBO and PDBI are 
ports for exclusive use which are used only for communication with the atx)ve described PLD 7. Those port 
- 50 PDBO and PDBI do not have connection lines for terminals. The port PDBO is used as an input buffer for 
inputting data on the data bus DB to the PLD 7 via an output line 193. And the port PDBI is used as an 
output buffer for outputting the output of the PLD 7 to the data bus DB via an input line 198. Function of 
respective non-volatile switch circuits (EPSW 10 to 15) will hereafter be described. 

55 

EPSWIO: 

It defines whether the port Pi should be used as a general purpose port coupled to the data bus or 
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shouid be used as a PLD input. 



EPSW11: 

It defines whether the port P2 should be used as a general purpose port coupled to the data bus or 
should be used as a PLD input or a PLD output. 



EPSW12: 

It defines whether the port P3 should be used as a general purpose port coupled to the data bus or 
should be used as a PLD output. 

EPSW13: 

It controls the input selector 200 and defines which wiring should be connected to the input of the 
logical product (AND) circuit 201 included in the PLD 7. Inputs comprise inputs from the ports PDBO. PI 
and P2, the address bus AB and a control bus CB containing the read signal RD. write signal WR and a 
clock signal. 

EPSW14: 

It controls the output circuit 203 and defines the output polarity and the like. 
EPSW15: 

It defines whether the PLD output should be outputted to the port P3 or should be outputted to the 
output buffer PDBI for the data bus. 

WRITING AND TESTING OF EPROM 

As heretofore described, the single chip microcomputer of the present embodiment comprises various 
circuits each using an EPROM device which is an electrically writable non-volatile semiconductor memory 
device. Data writing and testing with respect to this EPROM device are required. 

Fig. 21 shows configuration for implementing data writing and testing with respect to the EPROM. In the 
write mode, circuits containing an EPROM device, i.e., circuit modules of 
® EPROM 4 for program. 

® micro EPROM 11a of a subprocessor channel A 10a, 
® control PLA 14a, 

® micro EPROM lib of a subprocessor channel B 10b. 
® control PLA i4b, 

® PLD 7. . 
(2> first programmable I/O 8. and 

® second programmable I/O 199 are connected to the common bus 9. 

On the other hand, circuit modules such as the CPU 2 and the RAM 3 which do not comprise an 
EPROM device are electrically interrupted from the common bus 9. 

In such a state, necessary informatiom is supplied from the outside of the semiconductor substrate 1 to 
respective circuit modules each comprising an EPROM device via a test port and the common bus 9 to 
perform writing and testing operation. Signal lines used to communicate with the outside of the semiconduc- 
tor substrate 1 at this time comprise a test data line 207. a test address line 208 and a test control line 209. 

Data to be written into the EPROM is inputted onto the test data line 207 at the time of write operation, 
whereas data read out from the EPROM is outputted onto the test data line 207 at the tinne of r ad 
operation. Onto the test address tine 208. selection information of the EPROM is inputted. Onto the test 
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control line 209, a test enable signal, and a write signal and a read signal for controlling high writing voltage. 

wnte operation and read operation are supplied. That is to say. this microcomputer changes over from the 

normal instruction execution operation (normal mode) to the write mode in response to a signal supplied 

onto the test control line 209. 
5 EPROM devices included in the above described circuit modules ® to ® are assigned to an identical 

address space, i.e.. those EPROM devices are so assigned that they may be continuously specified by the 

lest address line 208 in the write mode. It is thus possible to write information by using a signal generated 

by a commercially available standard EPROM writer. 

A method for testing the subprocessor will now be described. Fig. 22A shows configuration of one 
/o channel of the subprocessor. The subprocessor test is performed in three stages described below, and its 

control is performed in response to signals applied onto the test control line 209. 



(1) EPROM device test: 

Device test of EPROM devices such as test of data holding characteristics is performed by using the 
above described write mode into the EPROM. That is to say, read/write test is carried out with respect to 
PROM devices included in the control PLA 4 and the micro EPROM 1 1 via the test port 206 and the 
common bus 9 shown in Fig. 22A. 



(2) Semidynamic test: 

As shown in Fig. 22A. latch circuits 210 and 211 for test are disposed respectively between the control 
25 PLA 14 and the control circuit 12 and between the micro EPROM 11 and the control circuit 12. By using 
information latched in the latch circuits 210 and 211. the semidynamic test is performed. Its operation is 
shown in Fig. 22B. in the normal mode, there is executed a series of operation comprising (T) micro 
EPROM read cycle, @ decode cycle. <D register, status register SR read and processing execution cycle, 
and ® register and status register SR write cycle. In the semidynamic test mode, however, cycle ® 
30 among the above described cycles is replaced by test cycle 1 (TCi). 

In TCi, control data are set into the testing latch circuits 210 and 211 via the test port 206 and the 
common bus 9. That is to say. the same state as that obtained when the control signal from the control PLA 
14 and data from the micro EPROM are received is produced. Further, initial data are set into general 
purpose register included in the processing circuit 13. Manipulation of TCi heretofore described can be 
35 performed statically. 

After respective data have been set. the above described cycles (2) to ® are consecutively executed. 
After the cycle ® has been finished, operation is temporarily stopped and a test cycle 2 (TC2) is started. In 
the TC2, contents of the registers can be read out statically. By comparing contents of registers with 
expected values, therefore, the test result can be known. 
JO In Fig. 22A. information of the micro EPROM 11 is so shown as to be inputted to the control circuit 

always via the latch circuit 21 1 for test. In the normal mode, however, this latch circuit 211 simply functions 
only to latch information of the micro EPROM. 



-JS (3) Dynamic test: 

The control PLA 14 comprises a PLA for test which can be used only in this test mode. In the same 

way, the micro EPROM 1 1 comprises a test program region in a part of its address. Onto this test program 

region, test program is written in the above described test mode of (i). Operation of this dynamic test mode 
50 is identical with that of the normal mode excepting that a PLA for test and a micro EPROM region for test 

are selected. That is to say, if this dynamic test mode is specified, the address of a micro EPROM region 

for test is specified as initial address. 

As heretofore described, the present invention makes it possible to enhance flexibility of not only 

software but also hardware and implement a single chip microcomputer optimum for a wide range of 
55 application. Further, high speed processing of a plurality of functions becomes possible as a result of 

optimum pipeline control. Thus, performance and function which compare favorably with special purpose 

hardware. 

In the present embodiment, an example using an EPROM of ultraviolet ray erasing type as the non- 
23 
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volatile, semiconductor memory has been described. It is a matter of course that a similar effect can be 
obtained even when an EEPROM of electrical erasing type or a ROM exclusively used for read out is 
employed. 

Further, it is also possible to connect the above described subprocessor 6. PLD 7. and programmable 
5 I/O 8 and 199 together outside the semiconductor substrate via the common bus. 

Owing to the present invention, the general purpose property of a single chip microcomputer can be 
enhanced. In a wide range of application, the number of components included in the above described circuit 
around the single chip microcomputer can be reduced. Further, since the user can write logical information 
by its own hand, changes in specification and logic, if any, can be rapidly dealt with. Together with 
JO shortening in development interval, the cost is also significantly reduced. 

Further, since specifications for writing data into non-volatile devices are made equivalent to those for 
standard non-volatile semiconductor memories so that information may be written by using a standard 
PROM writer, a Special writing apparatus is not required. The cost saving effect at this point is also 
significant. . 

ts 

Claims 

1. A single chip microcomputer (1) so configured on a semiconductor substrate as to include a first 
20 processor (10a), said first processor comprising: 

(a) memory means (11): 

(b) a processing circuit (13) responsive to information stored in said memory means; 

(c) a plurality of address registers (ARO to AR7) for supplying addresses to said memory means: and 

(d) as many status registers (SRO to SR7) as said address registers. 

25 2. A microcomputer according to Claim 1, wherein said status registers (SRO to SR7) hold at least one 

out of zero information and carry information generated as a result of processing perfornned in said 
processing circuit (13). 

3. A microcomputer according to Claim 2. wherein said memory means (1 1) stores therein microinstruc- 
tions of said processing circuit. 
00 4. A microcomputer according to Claim 2. wherein said memory means (11) is a read only memory 

comprising an electrically writable non-volatile semiconductor memory device. 

5. A microcomputer according to Claim 4, wherein said first processor (IO) further comprises 

(e) selection means (14) for selecting a plurality of address register-status register pairs out of said 
plurality of address registers and said plurality of status registers, said selection means (14) being 

35 responsive to information written into said non-volatile semiconductor memory device to perform said 
selection. 

6. A microcomputer according to Claim 5. wherein said selection means (14) comprises a logic array 
structure (87, 89). 

7. A microcomputer according to Claim 5. wherein said selection means (14) seiecttvely supplies 
40 address data to said address registers (ARO to AR7). 

8. A microcomputer according to Claim 1. wherein 

latch means (103 to 111) are disposed between said memory means (11) and said processing circuit (13) 
and between said processing circuit (13) and said status registers (SRO to SR7), respectively, and 
said first processor (6) is subject to pipeline control. 
45 9. A microcomputer according to Claim 7. wherein said first processor (10) further comprises: 

(f) a control register (125) coupled to said selection means (14), and 

said selection means (14) selectively supplies address data to said address registers (ARO to AR7) in 
response to information stored in said control register (125). 

10. A microcomputer according to Claim 5, wherein said first processor (10) further comprises: 
50 (g) terminal means (67) for receiving a signal from outside of said microcomputer: and 

(h) transfer means (99). responsive to a signal supplied from said terminal means (67) to an input 
thereof, for transferring information (100) to said selection means (14). and 

said selection m ans (14) selects a plurality of address register-status register pairs in response to said 
information (100). 
55 11. A microcomputer according to Claim 10. wherein 

said terminal means (67) comprises a plurality of terminals (leO, lei, Ie2). and 
said transfer means (99) comprises: 

a plurality of detection means (102) for detecting transition points of signals supplied from said plurality of 
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terminals: and 

means (10) for giving priority orders to said plurality of detected signals. 

12. A single chip microcomputer (1) so coruigured on a semiconductor substrate as to include a first 
processor (lOa). said first processor comprising: 

5 (a) memory means (1 1) for storing therein microinstructions; 

(b) a processing circuit (13) responsive to a microinstruction stored in said memory means: 

(c) a plurality of address registers (ARO to ART) for supplying address to said memory means: and 

(d) means for holding, for an execution time of one step of said microinstruction, at least one cut of 
zero information and carry information generated as a result of processing performed in said processing 

to circuit (13). 

13. A microcomputer according to Claim 12. wherein said memory means (117) is a read only memory 
comprising an electrically writable non-volatile semiconductor memory device. 

14. A single chip microcomputer incorporating a first processor (10) on a semiconductor substrate, said 
first processor comprising: 

/5 (a) a memory (11) for storing therein microinstructions; 

(b) control means (12) for decoding information stored in said memory and for generating a control 
signal: and 

(c) processing means (13) controlled by said control means (12), and 
said processing means (13) comprising: 

20 an arithmetic and logic processing circuit (71) and a comparison circuit (CMP) so connected to a common 
input as to be simultaneously operable: and 

selection means (36) connected to said arithmetic and logic processing circuit (71) and said comparison 
circuit (CMP), said selection means (36) selecting and outputting. in an alternative way, a zero signal 
indicating that the result of processing penormed in said arithmetic and logic processing circuit (71) is 2ero 
25 and a coincidence signal indicating that the result of comparison performed in said comparison circuit 
(CMP) is coincidence. 

15. A microcomputer according to Claim 14. wherein said first processor further comprises 

(d) means (21), responsive to an output signal of said selection means (36), for controlling address of 
said memory (11) for storing therein microinstructions. 

30 16. A microcomputer according to Claim 15. wherein said first processor further comprises: 

(e) means (18). responsive to the output signal of said selection means (36). for outputting data to 
said terminal means. 

17. A microcomputer according to Claim 16. wherein said first processor further comprises: 

(f) status registers (SRO to SR7) for storing therein information of result of processing performed in 
75 said processing means (13). the output of said selection means (36) being stored into said status register. 

18. A microcomputer according to Claim 17. comprising: 

said processing means (13) further comprising a first register (29) and a second register (28): 

said comparison circuit (CMP) being means for comparing data stored in said first and second registers; 

and 

40 said arithmetic and logic processing circuit (71) being means for increasing the value of data stored in said 
first register, whereby in case the result of comparison of data stored in said first and second registers is 
coincidence, a signal indicating coincidence is generated and data of said first register is cleared, whereas 
in case of noncoincidence, a signal indicating noncoincidence is generated and the value of said first 
register is increased. 

-iS 19. A microcomputer according to Claim 17, comprising: 

said processing means (13) further comprising a first register (29) and a second register (28): 

said comparison circuit (CMP) being means for comparing data stored in said first and second registers; 

and 

said arithmetic and logic processing circuit (71 ) being means for increasing the value of data stored in said 
50 first register, whereby in case the result of comparison of data stored in said first and second registers is 

coincidence, a signal indicating coincidence is generated, whereas in case of noncoincidence, a signal 

indicating noncoincidence is generated, and the value of said first register is increased in both cases. 
20. A microcomputer according to Claim 17. comprising: 

said processing means (13) further comprising a first register (29) and a second register (28); 
55 said comparison circuit (CMP) being means for comparing data stored in said first and second registers; 

said arithmetic and logic processing circuit (71 ) being means for decreasing the value of data stored in said 

first register, and 

means for transferring data stored in said second register to said first register upon arrival of the value of 
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data of said first register at zero as a result of said decreasing. • 

21. A single chip microcomputer incorporating a first processor (10) on a semiconductor substrate, said 
first processor comprising: 

(a) a memory (11) for storing therein microinstructions: 
5 (b) control means (12) for decoding information stored in said memory and for generating a control signal; 

(c) a processing circuit (26) and register circuits (R8 to RIO) controlled by said processing control means 
(22): 

(d) bus means (3i) connected to said processing circuit (26); 

(e) terminal means (300) for receiving a signal from outside of said microcomputer; 

JO (f) input control means (15. 301) responsive to a signal supplied from said terminal means (300); 

said microinstruction including in one word thereof processing control information, register control informa- 
tion and input control information; 

said control means (12) including a processing control circuit (22) responsive to said processing control 
information and a register control circuit (23) responsive to said register control information; and 
75 said input control means (15. 301). responsive to said input control information, for coupling said register 
circuits (R8 to R11) to said bus means (31). 

22. A microcomputer according to Claim 21. wherein 

said register circuit comprises a plurality of registers (R8 to Rl 1), and 

said input control means (IS. 301) couples said plurality of registers (R8 to R11) independently to said bus 
20 means (31) in response to said input control information. 

.23. a single chip microcomputer incorporating a first processor (10) on a semiconductor substrate, said 
first processor comprising: 

(a) a memory (11) for storing therein microinstructions: 

(b) control means (12) for decoding information stored in said memory and for generating a control signal; 
25 (c) a processing circuit (26) and register circuits (RO. R2. R4. R8) controlled by said processing control 

means (22): 

(d) bus means (25) connected to said processing circuit (26); 

(e) terminal means (245) for outputting a signal to the outside of said microcomputer; 

(f) output control means (15, 241. 244) responsive to a signal supplied from said terminal means (245); 

30 said microinstruction including in one word thereof processing control information, register control informa- 
tion and output control information: 

said control means (12) including a processing control circuit (22) responsive to said processing control 
information and a register control circuit (23) responsive to said register control information: and 
said output control means (15. 241, 244), responsive to said output control information, for comparing data 
35 Stored in said register circuits (RO. R2. R4. R8) with data on said bus means (25) and for outputting result of 
said comparison to said terminal means. 

24. A microcomputer according to Claim 23. wherein 

said register circuit comprises a plurality of registers (RO. R2. R4, R8). and 

said output control means (15. 241. 244) compares data stored in said plurality of registers (RO. R2. R4. R8) 
40 independently with data of said bus means (25) in response to said output control information and outputs 
said comparison results independently to said terminal means. 

25. A single chip microcomputer incorporating a first processor (10) and input/output means (8) on a 
semiconductor substrate, said first processor comprising: 

(a) a memory (11) for storing therein microinstructions; 
45 (b) processing means (13), responsive to said microinstruction, for executing the instruction: 

(c) control means (15) for decoding information stored in said memory and for controlling said input/output 
means (8); 

said input/output means (8) comprising a plurality of input/output bits (130) capable of being specified by 
taking bit as unit; and 

50 means (15). responsive to said microcinstruction. for selecting at least one of said plurality of input/output 
bits and for specifying the function of said selected input/output bit. 

26. A microcomputer according to Claim 25. wherein 

a first input/output bit is selected and specified as input bit in response to first information (PcO of said 
microinstruction, and 

55 execution of an instruction in said processing means (13) is invalidated in response to a signal inputted from 
said first input/output bit. 

27. A microcomputer according to Claim 25. wherein 

a second input/output bit is selected and specified as input bit in response to s cond information (PO) of 
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said microinstruction, and 

a signal inputted from said second input/output bit is used as carry information (Ci) of said processing 
means (13). 

. 28. A microcomputer according to Claim 25. wherein 
5 a third input/output bit is selected and specified as output bit in response to third information (PI) of said 
microinstruction, and 

a signal responsive to at least one out of carry information (C) and zero information (Z) of said processing 
means (13) is outputted from said third input/output bit. 
29. A microcomputer according to Claim 25. wherein 
to a second input/output bit is selected and specified as input bit in response to second information (PO) of 
said microinstruction, and 

a third input/output bit is selected and specified as output bit in response to third information (PI) of said 
microinstruction, output from said third input/output bit being controlled in response to information inputted 
from said second input/output bit. 

;5 30. A microcomputer according to Claim 25, wherein said first processor further comprises: 

(d) means (21). responsive to information stored in said memory, for selecting address of said microinstruc- 
tion in which an instruction to be subsequently executed by said processing circuit (13) is stored, and 
a second input/output bit is selected and specified as input bit in response to second information (PO) of 
said microinstruction, said selection means (21) selecting said address in response to information inputted 

20 from said second input/output bit. 

31. A microcomputer according to any one of Claims l to 30. wherein said microcomputer further 
comprises a second processor (lOb). and said second processor (10b) has the same configuration as that 
of said first processor (10a). 

32. A microcomputer according to Claim 31, wherein said first processor and said second processor are 
25 connected together via first interface means (19). 

33. A microcomputer according to Claim 32. wherein said first interface means (19) comprises a 
semaphore flag (S) having a plurality of bits, and both said first and said second processors can gain 
access to said semaphore flag (S). 

34. A microcomputer according to any one of Claims 1 to 30. wherein 

30 said microcomputer further comprises a third processor (5) including a CPU (2). and 
said CPU (2) is coupled to said first processor (lOa) via a common bit (9). 

35. A microcomputer according to Claim 34. wherein said first processor (lOa) has an instruction set 
different from that of said third processor (5). 

36. A microcomputer according to Claim 34. wherein 

35 said third processor (5) comprises interrupt processing means (2). and 

said first processor (10a) comprises interrupt permission request means (47. 56). said interrupt processing 
means (2) being coupled to said interrupt permission request means (17. 56). 

37. A microcomputer according to Claim 34. wherein said first processor further comprises second 
interface means (16) and a first processor bus (46). and 

JO said first processor bus (46) is coupled to said third processor (5) via said second interface means 16) and 
said common bus (9). 

38. A microcomputer according to Claim 37. wherein said first processor bus (46) is a bus that said 
third processor (5) can directly gain access to. 

39- A microcomputer according to Claim 34. wherein 

45 said common bus (9) comprises a data bus (DB) and an address bus (AB). and 

said second interface means (16) is connected to a read signal line (RDi) and a write signal line (WRI) of 
said second processor (5), data transfer between said first processor (10a) and said third processor (5) 
being performed in response to signals on said read signal line (RDi)^ said write signal line (WRI) and said 
address bus (AB). 

50 40, A microcomputer according to Claim 39. comprising: 

said microcomputer (1) including memory means (3. 4) and terminal connection means (199) connected to 
said common bus (9); 

said first processor (lOa) including a second processor bus (31) and memory access means (53, 54. 48. 49. 
RD2. WR2. BRQ. BAK. REP) connected to said second processor bus <31). said data bus (DB) and said 
55 address bus (AB); 

said memory access means including request means (BRQ) for requesting possessory right of bus from 
said first processor (5); and 

said memory access means gaining access to said memory means (3. 4) and terminal connection means 
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(199) by executing an instruction described in an instruction field of a read only memory (11) of said first 

processor (lOa). 

41 A microcomputer according to claim 40. wherein 

said terminal connection means (199) is connected to an external memory disposed outside said microcom- 

5 puter (1). and ^ . 

said memory access means (53, 54. -) gains access to said external memory by executing said 

instruction. 

42 A microcomputer according to Claim 41. wherein said external memory composes a dynamic 
random access memory, and said memory access means (53. 54. -) refreshes said dynannic random 

10 access memory by executing said instruction. 

43 A microcomputer according to Claim 25, comprising: 

said microcomputer (1) further including a third processor (5) coupled to said first processor (lOa) via the 

common bus (9); 

said microcomputer including terminal means (67) coupled to said inpuVoutput bit (130); 

IS said input/output bit (130) including input means (131) and output means (130); 

said input means (131) being selectively supplied with signals from said terminal means (67) and said 
output means, to output a signal selectively to said common bus (9) and said first processor (lOa): and 
said output means (132) being selectively supplied with signals from said common bus (9) and said first 
processor (10a) to output a signal selectively to said terminal means (67) and said input means (131). 

20 44 A microcomputer according to Claim 43. wherein said output means (132) comprises: 

first switch means (EPSWI) for selecting either said common bus (9) or said first processor (10a) as input: 
second switch means (EPSW2. 3) for selecting either said terminal means (67) or said input means (131) as 

output; and . 
third switch means (EPSW2. 161) for setting output function to said terminal means (67) or said input 

25 "^^^^^^J^^l^j^^^^^^p^^g^ according to Claim 44, wherein output function controlled by said third switch 
means (EPSW2. 161) comprises: 

function of taking an inputted signal into first latch means (140) and outputting it; 

function of latching a signal inputted from said common bus (9) into second latch means, transfernng the 
30 signal from said second latch means to third latch means in response to output of said first processor, and 
outputting the output of said third latch means: or 

function of inverting output of outputting fourth latch means and inhibiting output thereof. 

46 A microcomputer according to Claim 43. wherein said input means (131) comprises: 
fourth switch means (EPSW3. 4) for selecting either said terminal means (67) or said output means (132) as 
j5 output to said common bus (9); 

fifth switch means (EPSW4) for selecting either said terminal means (67) or said output means (132) as 
output to said first processor (10a): and 

sixth switch means (EPSW4. 158) for setting input function supplied from said terminal means (167). 

47, A microcomputer according to Claim 46. wherein the function set by said sixth switch means 
40 (EPSW4. 158) comprises: 

both edges detection function; 
positive edge detection function; 
negative edge detection function: or 

function of transferring terminal information via an amplifier. 
45 48. A non-volatile switch circuit (EPSW) including a non-volatile semiconductor memory device, said 

switch circuit comprising; Kiir^e 
a cross coupled circuit including two pairs of p-channel MOS transistors (165. 166) and n-channel MOS 
transistors (167. 168) respectively having drain electrodes connected together and gate electrodes con- 
nected by common gate wiring, drain electrodes of one pair being connected to gate electrodes of the other 
pair drain electrodes of the other pair being connected to gate electrodes of one pair, source electrodes of 
respective p-channel MOS transistors being connected to a first power supply line (174); and 
a non-volatile semiconductor memory circuit (184) disposed between a source electrode of at »east one of 
n-channel MOS transistors included in said transistor pairs and a second power supply line (175). said 
memory circuit including said non-volatil semiconductor memory device (170). 

49. A non-volatile switch circuit according to Claim 48. wherein said non-volatile semiconductor memory 

circuit (184) comprises: * w tho 

an n-channei (VtOS transistor (169) having high withstanding voltage, and one electrode connected to tne 
source electrode of an n-channel MOS transistor (168) included in said transistor pair; and 
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said non-volatile semiconductor memory device (170) connected to the other electrode of said n-channel 
MOS transistor (169) having high withstanding voltage and said second power supply line, said non-volatile 
switching further including a write circuit (l7i) to said non-volatile semiconductor memory device (170). 

50. A microcomputer according to any one of Claims 44 to 48. wherein said first to sixth switch means 
comprise; 

a cross coupled circuit including two pairs of p-channel MOS transistors (165. 166) and n-channel MOS 
transistors (167, 168) respectively having drain electrodes connected together and gate electrodes con- 
nected by common gate wiring, drain electrodes of one pair being connected to gate electrodes of the other 
pair, drain electrodes of the other pair being connected to gate electrodes of one pair, source electrodes of 
respective p-channel MOS transistors being connected to a first power supply tine (174); and 
a non-volatile semiconductor memory circuit (184) disposed between a source electrode of at least one of 
n-channel MOS transistors included in said transistor pairs and a second power supply line (175). said 
memory circuit including said non-volatile semiconductor memory device (170). 

51. A microcomputer according to Claim 31. wherein 

said microcomputer (1) further comprises a third processor (5). and 

said first processor (lOa) is coupled to said second processor (10b) via first interface means (19). said first 
processor (10a) and said second processor (10b) being coupled to said third processor (5) via second 
interface means, 

52. A microcomputer (1) so formed on a semiconductor substrate as to include a processing unit <6). 
said microcomputer (1) comprising: 

a common bus (9): and 

a circuit unit (4. 11, 14. 7. 8, 199) being connectable to said common bus (9) and so configured as to 
include therein an electrically writable non-volatile semiconductor memory device, said microcomputer 
changing over from a first mode for performing instruction executing operation by using said processing 
unit (6) to a second mode allowing to write information into said circuit unit in response to an externally 
supplied signal (209). 

53. A microcomputer according to Claim 52. wherein said microcomputer comprises input/output means 
(206) for receiving a selection signal (208) of a non-volatile memory device and a read/write specifying 
signal (209) inputted from the outside of said microcomputer, and 

said write or read data is transferred via said input/output means (206). 

54. A single chip microcomputer so configured on a semiconductor substrate as to include a first 
processor (10). a common bus (9) connected to said first processor (10). and input/output means (206) 
connected to said common bus (9). said first processor comprising: 

a read only memory (11): 

a processing control circuit (12, 13) responsive to information stored in said read only memory: and 
a register circuit (210, 211) connected to said common bus (9) and said processing control circuit (12, 13). 
said first processor transferring test data to said register circuit (210, 21 1) via said input/output means (206) 
in response to a control signal inputted via said input/output means (206). said first processor activating said 
processing control circuit in response to said test data stored in said register circuit (210. 211). 

55. A microcomputer according to Claim 54, wherein 

said read only memory (11) has first and second regions divided by address thereof, and said first 
processor (6) selectively executes microinstructions stored in said first and second regions in response to a 
control signal inputted via said input/output means (206). 
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